

### UNIT 7

Multi-level Gate Circuits NAND and NOR Gates



### This chapter includes:

- 7.1 Multi-level Gate Circuits
- 7.2 NAND and NOR Gates
- 7.3 Design of Two-Level NAND- and NOR- Gate Circuits
- 7.4 Design of Multi-Level NAND- and NOR- Gate Circuits
- 7.5 Circuit Conversion Using Alternative Gate Symbols
- 7.6 Design of Two-Level, Multiple Output Circuits
- 7.7 Multiple Output NAND- and NOR- Gate Circuits



## Learning Objectives

- 1. Design a minimal two-level or multi-level circuit of AND and OR gates to realize a given function. (Consider *both* circuits with an OR gate at the output and circuits with an AND gate at the output.)
- 2. Design or analyze a two-level gate circuit using any one of the eight basic forms (AND-OR, NAND-NAND, OR-NAND, NOR-OR, OR-AND, NOR-NOR, AND-NOR, and NAND-AND).
- 3. Design or analyze a multi-level NAND-gate or NOR-gate circuit.
- 4. Convert circuits of AND and OR gates to circuits of NAND gates or NOR gates, and conversely, by adding or deleting inversion bubbles.
- 5. Design a minimal two-level, multiple-output AND-OR, OR-AND, NAND-NAND, or NOR-NOR circuit using Karnaugh maps.

### Terminology:

- The maximum number of gates cascaded in series between a circuit input and the output is referred to as the number of levels of gates (not to be confused with voltage levels).
- \* AND-OR circuit means a two-level circuit composed of a level of AND gates followed by an OR gate at the output.
- \* OR-AND circuit means a two-level circuit composed of a level of OR gates followed by an AND gate at the output.
- OR-AND-OR circuit means a three-level circuit composed of a level of OR gates followed by a level of AND gates followed by an OR gate at the output.
- Circuit of AND and OR gates implies no particular ordering of the gates; the output gate may be either AND or OR.

### Different Realizations for the Same Expression, Z:

FIGURE 7-1 Four-Level Realization of Z © Cengage Learning 2014



FIGURE 7-2
Three-Level
Realization of Z
© Cengage Learning 2014



### Example 1:

Example of Multi-Level Design Using AND and OR Gates **Problem:** Find a circuit of AND and OR gates to realize

$$f(a, b, c, d) = \sum m(1, 5, 6, 10, 13, 14)$$

Consider solutions with two levels of gates and three levels of gates. Try to minimize the number of gates and the total number of gate inputs. Assume that all variables and their complements are available as inputs.

Solution:

First, simplify f by using a Karnaugh map (Figure 7-3):

FIGURE 7-3
© Cengage Learning
2014



### Example 1 (continued):

This leads directly to a two-level AND-OR gate circuit (Figure 7-4):

#### FIGURE 7-4

© Cengage Learning 2014



Factoring Equation (7-1) yields

$$f = c'd(a' + b) + cd'(a + b)$$
(7-2)

### Example 1 (continued):

which leads to the following three-level OR-AND-OR gate circuit (Figure 7-5):

FIGURE 7-5

© Cengage Learning 2014



Both of these solutions have an OR gate at the output. A solution with an AND gate at the output might have fewer gates or gate inputs. A two-level OR-AND circuit corresponds to a product-of-sums expression for the function. This can be obtained from the 0's on the Karnaugh map as follows:

$$f' = c'd' + ab'c' + cd + a'b'c$$
(7-3)

$$f = (c+d)(a'+b+c)(c'+d')(a+b+c')$$
(7-4)

### Example 1 (continued):

Equation (7-4) leads directly to a two-level OR-AND circuit (Figure 7-6):



### Example 1 (continued):

To get a three-level circuit with an AND-gate output, we partially multiply out Equation (7-4) using (X + Y)(X + Z) = X + YZ:

$$f = [c + d(a' + b)][c' + d'(a + b)]$$
(7-5)

Equation (7-5) would require four levels of gates to realize; however, if we multiply out d'(a + b) and d(a' + b), we get

$$f = (c + a'd + bd)(c' + ad' + bd')$$
(7-6)

which leads directly to a three-level AND-OR-AND circuit (Figure 7-7):

### Example 1 (continued):

#### FIGURE 7-7

© Cengage Learning 2014



For this particular example, the best two-level solution had an AND gate at the output (Figure 7-6), and the best three-level solution had an OR gate at the output (Figure 7-5). In general, to be sure of obtaining a minimum solution, one must find both the circuit with the AND-gate output and the one with the OR-gate output.

### Example 1 (continued):

If an expression for f' has n levels, the complement of that expression is an n-level expression for f. Therefore, to realize f as an n-level circuit with an AND-gate output, one procedure is first to find an n-level expression for f' with an OR operation at the output level and then complement the expression for f'. In the preceding example, factoring Equation (7-3) gives a three-level expression for f':

$$f' = c'(d' + ab') + c(d + a'b')$$
  
=  $c'(d' + a)(d' + b') + c(d + a')(d + b')$  (7-7)

Complementing Equation (7-7) gives Equation (7-6), which corresponds to the three-level AND-OR-AND circuit of Figure 7-7.

### **NAND Gates:**



A **NAND Gate** is equivalent to an AND gate followed by an inverter, or AND-NOT gate (as shown in Figure 7-8(b)). The n-input NAND gate's output is:

$$F = (X_1 X_2 \dots X_n)' = X_1' + X_2' + \dots + X_n'$$

The output of this gate is 1 iff one or more of its inputs are 0.

### **NOR Gates:**

FIGURE 7-9 NOR Gates

© Cengage Learning 2014



(a) Three-input NOR gate



(b) NOR gate equivalent



(c) n-input NOR gate

A **NOR Gate** is equivalent to an OR gate followed by an inverter, or an OR-NOT gate. The n-inputs NOR gate's output is:

$$F = (X_1 + X_2 + \cdots + X_n)' = X_1'X_2' \dots X_n'$$

### **Functionally Complete Operations and Gates:**

- A set of logic operations is said to be *functionally* complete if any Boolean function can be expressed in terms of this set of operations.
- If a single gate forms a functionally complete set by itself, then any switching function can be realized using only gates of that type, i.e. NAND, NOR.



## Procedure to Determine if Functionally Complete:

- 1. Write out a minimum sum-of-products expression for the function realized by each gate.
  - If no complement appears in any of these expressions, then NOT cannot be realized, and the set is not functionally complete.
  - □ If a complement appears in one of the expressions, then NOT can generally be realized by an appropriate choice of inputs to the corresponding gate. (We will always assume that 0 and 1 are available as gate inputs).

## Procedure to Determine if Functionally Complete (continued):

2. Next, attempt to realize AND or OR, keeping in mind that NOT is now available. Once AND or OR has been realized, the other one can always be realized using DeMorgan's laws if no more direct procedure is apparent. For example, if OR and NOT are available, AND can be realized by

$$XY = (X' + Y')'$$
 (7-10)

## Conversion of AND and OR Gate Circuits to NAND and NOR:

❖ A two-level circuit composed of AND and OR gates is easily converted to a circuit composed of NAND gates or NOR gates. This conversion is carried out by using F = (F) and then applying DeMorgan's laws:

$$(X_1 + X_2 + \cdots + X_n)' = X_1' X_2' \dots X_n'$$
 (7-11)

$$(X_1X_2...X_n)' = X_1' + X_2' + \cdots + X_n'$$
 (7-12)

### Example 2:

The following example illustrates conversion of a minimum sum-of-products form to several other two-level forms:

$$F = A + BC' + B'CD = [(A + BC' + B'CD)']'$$

$$= [A' \cdot (BC')' \cdot (B'CD)']'$$

$$= [A' \cdot (B' + C) \cdot (B + C' + D')]'$$

$$= A + (B' + C)' + (B + C' + D')'$$
(by 7-12) (7-15)
$$= A + (B' + C)' + (B + C' + D')'$$
(by 7-12) (7-16)

Equations (7-13), (7-14), (7-15), and (7-16) represent the AND-OR, NAND-NAND, OR-NAND, and NOR-OR forms, respectively, as shown in Figure 7-11.

Rewriting Equation (7-16) in the form

$$F = \{ [A + (B' + C)' + (B + C' + D')']' \}'$$
(7-17)

leads to a three-level NOR-NOR-INVERT circuit. However, if we want a two-level

### Example 2 (continued):

leads to a three-level NOR-NOR-INVERT circuit. However, if we want a two-level circuit containing only NOR gates, we should start with the minimum product-of-sums form for F instead of the minimum sum of products. After obtaining the minimum product of sums from a Karnaugh map, F can be written in the following two-level forms:

$$F = (A + B + C)(A + B' + C')(A + C' + D)$$

$$= \{ [(A + B + C)(A + B' + C')(A + C' + D)]' \}'$$

$$= [(A + B + C)' + (A + B' + C')' + (A + C' + D)']'$$

$$= (A'B'C' + A'BC + A'CD')'$$

$$= (A'B'C')' \cdot (A'BC)' \cdot (A'CD')'$$
(by 7-11) (7-21)

Equations (7-18), (7-19), (7-20), and (7-21) represent the OR-AND, NOR-NOR, AND-NOR, and NAND-AND forms, respectively, as shown in Figure 7-11. Two-level AND-NOR (AND-OR-INVERT) circuits are available in integrated-circuit form. Some types of NAND gates can also realize AND-NOR circuits when the so-called *wired OR* connection is used.

### **Eight Basic Forms for Two-Level Circuits:**



### **Eight Basic Forms for Two-Level Circuits**

(continued): F = (A + B + C)(A + B' + C')(A + C' + D) (7-18)



F = (A'B'C' + A'BC + A'CD')' (7-20)

## Procedure for Designing a Minimum Two-Level NAND-NAND circuit:

- Find a minimum sum-of-products expression for F.
- Draw the corresponding two-level AND-OR circuit.
- Replace all gates with NAND gates leaving the gate interconnections unchanged.
   If the output gate has any single literals as inputs, complement these literals.



## Procedure for Designing a Minimum Two-Level NOR-NOR circuit:

- Find a minimum product-of-sums expression for F.
- Draw the corresponding two-level OR-AND circuit.
- Replace all gates with NOR gates leaving the gate interconnections unchanged.
   If the output gate has any single literals as inputs, complement these literals.

This procedure is similar to that used for designing NAND-NAND circuits. Note, however, that for the NOR-NOR circuit, the starting point is a minimum product of sums rather than a sum of products.

## Procedure to Design Multi-Level NAND-Gate Circuits:

- Simplify the switching function to be realized.
- Design a multi-level circuit of AND and OR gates. The output gate must be OR.
   AND-gate outputs cannot be used as AND-gate inputs; OR-gate outputs cannot be used as OR-gate inputs.
- Number the levels starting with the output gate as level 1. Replace all gates with NAND gates, leaving all interconnections between gates unchanged. Leave the inputs to levels 2, 4, 6, . . . unchanged. Invert any literals which appear as inputs to levels 1, 3, 5, . . . .

### Example 3:



 $F_1 = a'[b' + c(d + e') + f'g'] + hi'j + k$ Figure 7-13 shows how the AND-OR circuit for  $F_1$  is converted to the corresponding NAND circuit.

#### FIGURE 7-13

Multi-Level Circuit Conversion to NAND Gates

> © Cengage Learning 2014



(a) AND-OR network



(b) NAND network

### **Alternative Gate Symbols:**

Alternate symbol for inverters:



The following gate symbols have been derived using DeMorgan's Laws.



### **NAND Gate Circuit Conversion:**

#### FIGURE 7-15

NAND Gate Circuit Conversion

© Cengage Learning 2014



(a) NAND gate network



(b) Alternate form for NAND gate network



(c) Equivalent AND-OR network

### **NOR Gate Circuit Conversion:**

#### FIGURE 7-16 Conversion to

NOR Gates

© Cengage Learning 2014



(a) Circuit with OR and AND gates



(b) Equivalent circuit with NOR gates

### Conversion of AND-OR Circuit to NAND Gates:

#### FIGURE 7-17

Conversion of AND-OR Circuit to NAND Gates

© Cengage Learning 2014







(b) First step in NAND conversion



(c) Completed conversion

### Procedure to Convert to a NAND (or NOR) Circuit:

- 1. Convert all AND gates to NAND gates by adding an inversion bubble at the output. Convert all OR gates to NAND gates by adding inversion bubbles at the inputs. (To convert to NOR, add inversion bubbles at all OR-gate outputs and all AND-gate inputs.)
- 2. Whenever an inverted output drives an inverted input, no further action is needed because the two inversions cancel.
- 3. Whenever a noninverted gate output drives an inverted gate input or vice versa, insert an inverter so that the bubbles will cancel. (Choose an inverter with the bubble at the input or output as required.)
- 4. Whenever a variable drives an inverted input, complement the variable (or add an inverter) so the complementation cancels the inversion at the input.

### Example 3:

Multi-level circuits reduce gate fan-in. See the example below:

$$F = D'E + BCE + AB' + AC' \tag{7-22}$$

A two-level AND-OR circuit implementing F requires one 4-input OR, one 3-input AND, and three 2-input ANDs. To reduce the fan-in, F can be factored.

$$F = A(B' + C') + E(D' + BC)$$
 (7-23)

The resulting four-level circuit using AND and OR gates is shown in Figure 7-18.

FIGURE 7-18 Limited Fan-In Circuit

© Cengage Learning 2014



### Example 3 (continued):

Since the output gate is an OR, the circuit can be converted to NAND gates without increasing the number of levels; Figure 7-19 is the result. Note that the three-level OR with inputs B' and C' and the four-level AND with inputs B and C both become a NAND with inputs B and C; hence, both can be replaced by the same gate.



Reducing the fan-in for some functions requires inserting inverters. The fan-in for F = ABC + D can be reduced to 2 by factoring F as F = (AB)C + D. If this is implemented using two-input NAND gates, an inverter is required and the resulting circuit has four levels.

# Design of Two-Level, Multiple Output Circuits

### Example 4:

Design a circuit with four inputs and three outputs which realizes the functions

$$F_1(A, B, C, D) = \sum m(11, 12, 13, 14, 15)$$

$$F_2(A, B, C, D) = \sum m(3, 7, 11, 12, 13, 15)$$

$$F_3(A, B, C, D) = \sum m(3, 7, 12, 13, 14, 15)$$
(7-24)

First, each function will be realized individually. The Karnaugh maps, functions, and resulting circuit are given in Figures 7-20 and 7-21. The cost of this circuit is 9 gates and 21 gate inputs.

FIGURE 7-20 Karnaugh Maps for Equations (7-24)

© Cengage Learning 2014







# Design of Two-Level, Multiple Output Circuits

### Example 4 (continued):

#### FIGURE 7-21

Realization of Equations (7-24)

© Cengage Learning 2014



#### FIGURE 7-22

Multiple-Output Realization of Equations (7-24)

© Cengage Learning 2014



# Design of Two-Level, Multiple Output Circuits

## Determination of Essential Prime Implicants for Multiple-Output Realization:

- We can find prime implicants, which are essential to one of the functions and to the multiple-output realization by a modification of the procedure used for the single-output case.
- In particular, when we check each 1 on the map to see if it is covered by only one prime implicant, we will only check those 1's which do not appear on the other function maps.

# Design of Two-Level, Multiple Output Circuits

## Determination of Essential Prime Implicants for Multiple-Output Realization:



© Cengage Learning 2014



(a) Solution with maximum number of common terms requires 8 gates, 26 inputs



(b) Best solution requires 7 gates, 18 inputs and has no common terms

## Design of Multiple Output NANDand NOR- Gate Circuits

### Converting a Two-Output Circuit to NOR Gates:

(a) Network of AND and OR gates



(b) NOR network